
Excelize 是 Go 語言編寫的用於操作 Office Excel 檔案基礎庫,基於 ECMA-376,ISO/IEC 29500 國際標準。可以使用它來讀取、寫入由 Microsoft Excel™ 2007 及以上版本創建的電子錶格檔案。支持 XLAM / XLSM / XLSX / XLTM / XLTX 等多種檔案格式,高度兼容帶有樣式、圖片(表)、樞紐分析表、切片器等複雜組件的檔案,並提供流式讀寫 API,用於處理包含大規模數據的活頁簿。可應用於各類報表平台、雲計算、邊緣計算等系統。入選 2020 Gopher China - Go 領域明星開源項目 (GSP)、 2018 開源中國碼雲 Gitee 最有價值開源項目 GVP,目前已成為 Go 語言最受歡迎的 Excel 檔案基礎庫。
2023年4月10日,社區正式釋出了 2.7.1 版本,該版本包含了多項新增功能、錯誤修復和兼容性提升優化。下面是有關該版本更新內容的摘要,完整的更改列表可查看 changelog。
此版本中最顯著的變化包括:
ChartLine 數據類型中的 Color 字段RichTextRun 數據類型代替 ShapeParagraph
Fill 代替 Shape 數據類型中的 Color 字段AutoFilterListOptions
TableOptions 重命名為 Table
AddChart 改為使用 ChartType 類型枚舉值指定圖表類型func (f *File) AutoFilter(sheet, rangeRef string, opts *AutoFilterOptions) error 修改為 func (f *File) AutoFilter(sheet, rangeRef string, opts []AutoFilterOptions) error
func (f *File) AddPictureFromBytes(sheet, cell, name, extension string, file []byte, opts *GraphicOptions) error 修改為 func (f *File) AddPictureFromBytes(sheet, cell string, pic *Picture) error
func (f *File) GetPicture(sheet, cell string) (string, []byte, error) 修改為 func (f *File) GetPictures(sheet, cell string) ([]Picture, error)
func (f *File) AddVBAProject(bin string) error 修改為 func (f *File) AddVBAProject(file []byte) error
func (f *File) GetComments() (map[string][]Comment, error) 修改為 func (f *File) GetComments(sheet string) ([]Comment, error)
func (f *File) AddTable(sheet, rangeRef string, opts *TableOptions) error 修改為 func (f *File) AddTable(sheet string, table *Table) error
func (sw *StreamWriter) AddTable(rangeRef string, opts *TableOptions) error 修改為 func (sw *StreamWriter) AddTable(table *Table) error
SetSheetDimension 與 GetSheetDimension 以支持設定與獲取工作表已用區域,相關 issue #1463
NewStyle 現已支持 17 種漸變填充樣式AddPicture 添加圖片時,現已允許插入 BMP 格式圖片GetPictures 支持讀取被添加至同一存儲格中的多張圖片SetConditionalFormat 支持設定帶有「如果為真則停止」和「圖標集」條件的條件式格式規則SetConditionalFormat 支持設定在條件式格式中使用帶有純色填充樣式的數據條,並支持指定數據條的顏色,相關 issue #1462
AddChart 支持設定圖表中各個數據系列使用自定義填充顏色,相關 issue #1474
AddChart 支持設定氣泡圖圖表中各個系列氣泡的大小AddChart 支持設定子母餅圖和復合條餅圖中第二繪圖區域的數據系列AddChart 支持為圖表中數據標籤設定自定義數字格式,相關 issue #1499
AddTable 支持在創建表格時指定是否包含標題行AddTable 創建表格時增加對表格名稱的校驗,並導出了錯誤常量 ErrTableNameLength,相關 issue #1468
AutoFilter 支持為篩選範圍內的多個列設定篩選條件CalcCellValue 現已支持指定是否為公式計算結果應用數字格式CalcCellValue 對於以下公式函數加入了雙字節字符的支持:LEFT, LEN, LENB, MID, MIDB, RIGHT 和 RIGHTB,相關 issue #1476
CalcCellValue 函數對於存在錯誤的公式將在計算結果中返回公式錯誤代碼,並將詳細錯誤信息在 error 數據類型的返回值中返回,相關 issue #1490
GetCellHyperLink 函數支持獲取合併存儲格中的超鏈接ChartType 以表示圖表類型枚舉感謝 Excelize 的所有貢獻者,以下是為此版本提交代碼的貢獻者列表: